html, body {font-family: Comic Neue;
height: 100%;
    padding: 0;
    margin: 0;
      min-height: 0;
        display: flex;
        flex-direction: column;
         overflow-x: clip;
}
h1 {
    margin-top: 0;
}
button {font-family: Comic Neue;
font-size: 18px;
font-weight: bold;}

.Bienvenue, .Welcome, .quatre {text-align: center;
background-color: black;
color:lightblue}
.oasis {text-align: center;
background-color: black;
color:yellow}
.Normal {background-color: lightsteelblue;
text-align: center;}
.Psy {background-color: pink;
text-align: center;}
.Ane {background-color: yellow;
text-align: center;}
.Tourisme {background-color: orange;
    text-align: center;}
.Effondrement {background-color: black;
text-align: center;
color: white;}
.Ruines {background-image: "Itsgettingnoisy.jpg";
text-align: center}
.Beauté {background-color: pink}
.Foire, .varia {background-color: black;
  color: lightblue;
text-align: center;
margin-top:0;
margin-bottom:0;}
.ver {background-color: black;
  color: yellow;
text-align: center;
margin-top:0;
margin-bottom:0;}
.brume {background-color: black;
  color: lightblue;
text-align: center;
margin-top:0;
margin-bottom:0;}
.Exuvie {background-color: paleturquoise;
text-align: center}
.Machine {background-color: darkblue;
color: lightblue;
text-align: center}
.Bete {background-color: rgb(226, 31, 226);
text-align: center}
.contact {background-color: black;
  color:cyan;
text-align: center}
#Anatomie {width: 70%;
height: auto;}
 #Minos, #Danse, #doggy, #juge, #Miam, #Existenz, #Welcome, #Train, #lov, #Royaume, #euh, #Lutte, #Quiet, #Scared, #Chez, #YOUKNOW, #Mange,#Zougz, #ADOPTED {width: 55%;
    height: auto;}
#Brouting, #Ténias, #deep, #truelove, #voix, #Symbiose,  #worm3, #Origins, #Catharsis, #Chien, #Rendre, #Je, #best, #Flottant,  #Cuisant, #godbrain, #Vol, #manger, #turing {height: auto;
width: 35%;}
#Yeuxx, #gigabrain, #noisy, #worm1, #worm2, #tafs {height:auto;
width: 75%;}
#canvas, #Infini {height:auto;
width: 85%;}
#Pasmiam, #Présent, #Cerveau, #dream, #Bien, #lv, #Pretty, #Simple, #Clope, #Hell, #Birds, #Body, #Justhave, #Soul, #Créa, #Tree, #Prison {height: auto;
width: 35%;
}
.btn {
  display: inline-block;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 25px;
  border-radius: 10px;
}
.btnwel {
  justify-content: right;
  margin-top: 2px;
  margin-bottom: 2px;
  font-size: 25px;
  border-radius: 10px;
}

.Brix, .Glarg {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.obs {
  display: flex;
  justify-content: center;
  gap: 30px;
}
.article-figure {
  width: fit-content;
  max-width: 100%;
  margin: 32px auto;
  text-align: center;
}

.article-figure img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.article-figure figcaption {
  margin-top: 10px;
  color: #7bd7ff;
  font-size: 0.9rem;
  line-height: 1.4;
  font-style: italic;
  text-align: center;
}

img {
  max-width: 100%;
  height: auto;
}

#Happy, #Friend, #Justhave2, #Pretty { width: 430px;
height:auto }
/* Centre les légendes sous les images : toujours foutre un figure !!!!!*/
figure {
  text-align: center; 
}
.btnz {background-color:black;
color:lightsteelblue;
font-family: Comic Neue;
border:none;
font-size: 20px;
}
.btn1 {background-color: lightsteelblue;   background: radial-gradient(circle, #ff6b6b 0%, #ff6b6b 30%, yellow 100%);}
.btn1:hover {box-shadow: 0 0 30px red, 0 0 30px orangered}
.btn1b {background: radial-gradient(ellipse at center, lightsteelblue 50%, black
   100%); border:none; border-radius: 50px;}
.btn1b:hover {box-shadow: 0 0 30px slategray, 0 0 30px slategray}
.btn2 {background: radial-gradient(ellipse at center, pink 30%, yellow 100%);}
.btn2:hover {box-shadow: 0 0 30px palevioletred, 0 0 30px palevioletred}
.btn3, .btn3b {background: radial-gradient(ellipse at center, rgb(246, 255, 0) 30%, yellow 100%);}
.btn3:hover, .btn3b:hover, .btnOO:hover, {box-shadow: 0 0 30px yellow, 0 0 30px yellow}
.btn3b {background: radial-gradient(ellipse at center, yellow 0%, yellow 40%, yellow 100%); border:none; border-radius: 50px; }
.btn3b:hover {box-shadow: 0 0 30px yellow, 0 0 30px yellow}
.btnOO {background: radial-gradient(ellipse at center, black 0%, rgb(97, 97, 6) 100%); }
.btnOO:hover {box-shadow: 0 0 30px yellow, 0 0 30px yellow}
.btn4 {background-color: orange;}
.btn4:hover {box-shadow: 0 0 30px orangered, 0 0 30px orangered}
.btn5 {background: radial-gradient(ellipse at center, black 0%, yellow
   100%);color: white}
.btn5:hover {box-shadow: 0 0 30px black, 0 0 30px black}
.btn5b {background: radial-gradient(ellipse at center, white 0%, black 40%, black 100%);color: white; border-radius: 50px;border:none}
.btn5b:hover {box-shadow: 0 0 30px darkgray, 0 0 30px darkgrey}
.btn6 {background: radial-gradient(ellipse at center, cyan 0%, yellow 100%);}
.btn6:hover {box-shadow: 0 0 40px lightseagreen, 0 0 40px lightseagreen}
.btn6b {background: radial-gradient(ellipse at center, cyan 0%, cyan 50%, black 100%);}
.btn6b:hover {box-shadow: 0 0 40px lightseagreen, 0 0 40px lightseagreen}
.btn7 {background: radial-gradient(ellipse at center, rgb(199, 89, 205) 0%, yellow
   100%)}
.btn7:hover {box-shadow: 0 0 30px pink, 0 0 30px pink}
.btn7b {background-color: black; color: white}
.btn7b:hover {box-shadow: 0 0 30px white, 0 0 30px white}
.btn8 {background: radial-gradient(ellipse at center, palevioletred 30%, yellow 100%);}
.btn8:hover {box-shadow: 0 0 30px palevioletred, 0 0 30px palevioletred}
.btnm {background: radial-gradient(ellipse at center, blue 30%, yellow 100%);}
.btnm:hover {box-shadow: 0 0 30px cyan, 0 0 30px cyan;}
.btnma {background: radial-gradient(ellipse at center, rgb(0, 0, 255) 50%, black
   100%);}
.btnma:hover {box-shadow: 0 0 30px cyan, 0 0 30px cyan;}
.btnmb {background: radial-gradient(ellipse at center, rgb(0, 0, 255) 50%, black
   100%);}
.btnmb:hover {box-shadow: 0 0 30px cyan, 0 0 30px cyan;}
.btnmc {background: radial-gradient(ellipse at center, white, cyan 40%, lightskyblue 100%); border:none;
border-radius: 70px;}
.btnmc:hover {box-shadow: 0 0 30px cyan, 0 0 30px cyan;}
.btn4 {background-color: greenyellow}
.btnv {background: radial-gradient(ellipse at center, red 50%, black
   100%); border:none; border-radius: 50px;}
.btnv:hover {box-shadow: 0 0 30px purple, 0 0 30px purple;}

.btnalign {
  display:flex;
  justify-content: space-around;
  align-items:center;
}
.btnalign button, .btnalign a {
  display:inline-block;
padding: 10px 20px;
margin:0;
}

a:visited {
    color: red;
  }
  
  a:hover {
    color: orange;
  }
  
  a:active {
    color: green;
  }

  .surprise {
    position: relative;
    display: inline-block; 
  }

  .btn4 {
    position: absolute; 
    top: 38%;         
    left: 65%;      
    transform: translate(-50%, -50%);
    padding: 5px 10px;
    background-color: rgba(0, 0, 0, 0.6); 
    color: greenyellow;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }


.Intro {
  display: inline-block;
  position: relative; 
  border-radius: 10px; 
}

.Intro img {
  display: block;
  margin:0 auto;
  border-radius: 10px; 
}

.Intro::after {
  content: '';
  position: absolute;
  top: 0; left: 15%; right: 15%; bottom: 0;
  border-radius: 10px;            
  border: 3px solid yellow;        
  box-shadow: 0 0 10px yellow, 0 0 20px yellow, 0 0 30px yellow; 
  pointer-events: none;    
  animation: haloPulse 2s infinite ease-in-out;
}
@keyframes haloPulse {
  0% {
    box-shadow: 0 0 20px 5px yellow;
  }
  50% {
    box-shadow: 0 0 40px 15px yellow; 
  }
  100% {
    box-shadow: 0 0 20px 5px yellow;
  }
}

.salut {  
  display: inline-block;
  position: relative; 
  border-radius: 10px; 
}
.salut img {
  display: block;
  margin:0 auto;
  border-radius: 10px; 
}

.salut::after {
  content: '';
  position: absolute;
  top: 0; left: 22.5%; right: 22.5%; bottom: 0;
  border-radius: 10px;            
  border: 3px solid white;          
  box-shadow: 0 0 25px white, 0 0 25px white, 0 0 45px white; 
  pointer-events: none;   

}

 .btn1 {
    position: absolute; 
    top: 30%;        
    left: 63%;        
    transform: translate(-50%, -50%); 
    padding: 15px 15px;
    background-color: grey (0, 0, 0, 0.6); 
    color: white;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }

  .btn5 {
    position: absolute; 
    top: 40%;        
    left: 75%;        
    transform: translate(-50%, -50%); 
    padding: 15px 15px;
    background-color: rgba(0, 0, 0, 0.6); 
    color: white;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }

  .btn2 {
    position: absolute;
    top: 30%;         
    left: 75%;       
    transform: translate(-50%, -50%); 
    padding: 15px 15px;
    background-color: pink (0, 0, 0, 0.6); 
    color: palevioletred;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }
  .btn3 {
    position: absolute; 
    top: 40%;         
    left: 63%;       
    transform: translate(-50%, -50%);
    padding: 15px 15px;
    background-color: yellow (0, 0, 0, 0.6); 
    color: orange;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }

      .btnOO {  
    position: absolute; 
    align-items: center;
    transform: translate(-50%, -50%);
    padding: 30px 30px;
    font-size: 120%;
    border: none;
    cursor: pointer;
    border-radius: 50px;
    color: yellow
  }
@keyframes aura {
  0% {
    color: #eaff00; 
  }
  33% {
    color: #ff0000; 
  }
  66% {
    color: #f60707;
  }
  100% {
    color: #def106;
  }}
  
  .btn6 {
    position: absolute; 
    top: 20%;        
    left: 65%;       
    transform: translate(-50%, -50%); 
    padding: 20px  20px;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }
    .btn6b {
    position: absolute; 
    align-items: center;
    transform: translate(-50%, -50%); 
    padding: 20px  20px;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }


  .btn7 {
    position: absolute;
    top: 20%;        
    left: 77%;       
    transform: translate(-50%, -50%);
    padding: 20px  20px;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }
  .btnm {
    position: absolute; 
    top: 10%;         
    left: 71%;      
    transform: translate(-50%, -50%); 
    padding: 20px  20px;
    background-color: rgb(57, 140, 255) (0, 0, 0, 0.6); 
    color: lightblue;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }
  .btnma {
    position: absolute;
align-items: center;
    transform: translate(-50%, -50%); 
    padding: 20px  20px;
    background-color: rgb(57, 140, 255) (0, 0, 0, 0.6); 
    color: lightblue;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }
 .btnmb {
    position: absolute;
align-items: center;
    transform: translate(-50%, -50%); 
    padding: 20px  20px;
    background-color: rgb(57, 140, 255) (0, 0, 0, 0.6); 
    color: lightblue;
    border: none;
    cursor: pointer;
    border-radius: 50px;
  }

  .news-frame {
    height: auto;
    width: 40%;
border-image: linear-gradient(45deg, #f06, cyan, yellow) 5;
box-shadow: 0 0 60px cyan, 0 0 60px cyan;
    border-radius: 30px;
    padding: 15px;
    overflow-y: auto; 
 margin: 0 auto
  }

  .news-item {
    margin-bottom: 30px;

  }

  .news-item h3 {
    margin: 0 0 5px 0;
    font-size: 18px;
    color: lightseagreen;
  }

  .news-item p {
    margin: 0;
    font-size: 14px;
    color: lightseagreen;
    text-shadow: 1px 1px 2px red(0, 0, 0, 0.8);
    box-shadow: 0 4px 8px red (0, 0, 0, 0.1);
  }

.navbar {
  display: flex;
  justify-content: space-between;
  font-family: Comic Neue;
  align-items: center;
  background: #111;
  color: lightblue;
  padding: 0.1rem 2rem;
  position: fixed; 
  flex-wrap: wrap;  
  width: 100%;
  min-width: 0;
  top: 0;
  z-index: 100;
  box-sizing: border-box;
  white-space: nowrap;
}
.navbar .links{
  display:flex; gap:.5rem;
  flex-wrap:wrap;                 
  min-width:0;                    
  max-width:100%;

}
.navbar .links a{
  padding:.5rem .75rem;
  text-decoration:none;
  overflow:hidden; 
  text-overflow:ellipsis; 
}

.navbar .logo { font-weight: bold; font-size: 1.2rem; }
.navbar .menu { list-style: none; display: flex; gap: 1rem; position: static;
  margin: 0; padding: 0; min-width:0; flex-wrap: wrap; }
.navbar .menu li a { color: cyan; text-decoration: none; }
.menu-icon { cursor: pointer; font-size: 1.5rem; }

@media (max-width:600px){
  .navbar .links{ flex-basis:100%; }
}

@media (max-width: 600px) {

  }
  .navbar .menu li { padding: 0.5rem 1rem; }
  .menu-icon { display: block; color: #fff; }


.telereve {
  cursor: pointer;       
  transition: background 0.3s, color 0.3s; 
  animation: neon 2s infinite;
}
@keyframes neon {
  0% {
    color: #ff00ff; 
    text-shadow: 0 0 5px #ff00ff, 0 0 10px #ff00ff, 0 0 20px #ff00ff;
  }
  33% {
    color: #00ffff; 
    text-shadow: 0 0 5px #00ffff, 0 0 10px #00ffff, 0 0 20px #00ffff;
  }
  66% {
    color: #9900ff;
    text-shadow: 0 0 5px #9900ff, 0 0 10px #9900ff, 0 0 20px #9900ff;
  }
  100% {
    color: #ff00ff;
    text-shadow: 0 0 5px #ff00ff, 0 0 10px #ff00ff, 0 0 20px #ff00ff;
  }}

.zagz  {
  font-size: 18px;    
  font-weight: bold;   
  color: cyan;       
  display: inline-block; 
  animation: pulse 30s infinite ease-in-out;
}

@keyframes pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.5); 
    opacity: 0.8;          
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.pul {
  animation: neon3 0.8s infinite;
}

@keyframes neon3 {
  0% {
    color: lightblue; 
  }
  50% {
    color: red; 
    text-shadow: 0 0 10px red, 0 0 20px red, 0 0 30px red;
    transform: scale(2);
  }

  100% {
    color: lightblue;
  }}

.libre {
animation: neon2 5s infinite;
}
@keyframes neon2 {
  0% {
    color: cyan; 
    text-shadow: 0 0 5px lightblue, 0 0 10px lightblue, 0 0 15px lightblue;
  }
  33% {
    color: lightblue; 
    text-shadow: 0 0 5px cyan, 0 0 10px cyan, 0 0 15px cyan;
  }
  66% {
    color: lightskyblue;
    text-shadow: 0 0 5px lightblue, 0 0 10px lightblue, 0 0 15px lightblue;
  }
  100% {
    color: lightblue;
    text-shadow: 0 0 5px lightskyblue, 0 0 10px lightskyblue, 0 0 15px lightskyblue;
  }}

.chaud { animation: neonrouge 5s infinite;}

.btnalign button {font-weight: bold;
  font-family: Comic Neue;
  max-width: 100%;
}
.btnalign { 
flex-wrap:wrap;  
 white-space:normal; 
  flex:1 1 clamp(9rem, 30%, 12rem); 
  min-width:0;   
}

.item { visibility: hidden; height: 0; overflow: hidden; transition: all 0.3s; }
.item.show { visibility: visible; height: auto; }

.gal:empty {
  display: none;
}
.gal:has(> *) { display: grid; }          

.gal:has(.item.show) { display: grid; } 
.Tout {
  flex: 1; 
background-color: black;
}
.spacer {
  flex: 1; 
  background-color: black; 
}
footer, footer p {  background-color: black;
  color: cyan;
  position: relative !important;  
  z-index: 9999 !important; 
  margin: 0;
  padding: 0;
  width: auto;
  min-height: 0;
  
}
.contact-form {
  background: black;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  max-width: 400px;
  width: 100%;
  align-items: center;
}

.contact-form h2 {
  margin-bottom: 1rem;
  text-align: center;
}

.contact-form label {
  display: block;
  margin-top: 1rem;
  font-weight: bold;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 0.7rem;
  margin-top: 0.3rem;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 1rem;
}

.contact-form button {
  margin-top: 1.5rem;
  width: 100%;
  padding: 0.8rem;
  background: #0077ff;
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  cursor: pointer;
  transition: 0.3s;
}

.contact-form button:hover {
  background: #005ad1;
}

.float-img{
  float: right;
  width: 160px;
  margin: 0 16px 12px 0;
  margin-right: 8%;
}
img.flip-x { transform: scaleX(-1); }

.artwork {
  max-width: 300px;
  cursor: zoom-in;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: auto;
}

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.88);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
  z-index: 9999;
}

.lightbox.open {
  opacity: 1;
  visibility: visible;
}

.lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  cursor: zoom-out;
  user-select: none;
  -webkit-user-drag: none;
}

.journal-page {
  max-width: 1100px;
  margin: 40px auto;
  padding: 48px;
  background:
    radial-gradient(circle at top left, rgba(0, 130, 255, 0.16), transparent 35%),
    radial-gradient(circle at bottom right, rgba(0, 220, 255, 0.10), transparent 38%),
    #060c1c;
  box-shadow:
    0 0 35px rgba(0, 150, 255, 0.18),
    0 20px 70px rgba(0, 0, 0, 0.75);
  border: 1px solid rgba(120, 210, 255, 0.28);
}

.journal-header {
  border-bottom: 4px double rgba(130, 220, 255, 0.55);
  padding-bottom: 24px;
  margin-bottom: 32px;
  text-align: center;
}

.journal-kicker {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  margin: 0 0 12px;
  color: #79d9ff;
}

.journal-header h1 {
  font-size: clamp(2.4rem, 7vw, 5.5rem);
  line-height: 0.9;
  margin: 0;
  text-transform: uppercase;
  color: #c8f3ff;
  text-shadow:
    0 0 12px rgba(100, 200, 255, 0.45),
    0 0 32px rgba(0, 130, 255, 0.24);
}

.journal-subtitle {
  max-width: 640px;
  margin: 18px auto 0;
  font-size: 1.1rem;
  font-style: italic;
  color: #8fdcff;
}

.journal-subtitle {
  max-width: 640px;
  margin: 18px auto 0;
  font-size: 1.1rem;
  font-style: italic;
}

.journal-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 22px;
  align-items: start;
}

.journal-block,
.journal-figure {
  background:
    linear-gradient(145deg, rgba(20, 70, 120, 0.36), rgba(4, 12, 28, 0.88));
  border: 1px solid rgba(130, 220, 255, 0.38);
  padding: 18px;
  box-shadow:
    inset 0 0 18px rgba(120, 220, 255, 0.08),
    0 0 22px rgba(0, 140, 255, 0.13);
  backdrop-filter: blur(4px);
}

.journal-block {
  grid-column: span 2;
  min-height: 170px;
}

.journal-block.wide {
  grid-column: span 4;
}

.journal-block h2 {
  font-size: 1.15rem;
  margin: 0 0 10px;
  text-transform: uppercase;
  color: #b9ecff;
  border-bottom: 1px solid rgba(130, 220, 255, 0.38);
  padding-bottom: 6px;
  text-shadow: 0 0 8px rgba(120, 220, 255, 0.35);
}

.journal-block p {
  font-size: 1rem;
  line-height: 1.55;
  margin: 0;
  text-align: justify;
  color: #7bd7ff;
}

.journal-figure {
  grid-column: span 2;
  margin: 0;
  transform: rotate(-0.4deg);
}

.journal-figure:nth-of-type(even) {
  transform: rotate(0.7deg);
}

.journal-figure.small {
  grid-column: span 1;
}

.journal-figure.tall {
  grid-column: span 2;
  grid-row: span 2;
}

.journal-figure img {
  width: 100%;
  display: block;
  cursor: zoom-in;
  filter: contrast(1.05) saturate(0.85);
}

.journal-figure figcaption {
  margin-top: 8px;
  font-size: 0.78rem;
  font-style: italic;
  border-top: 1px solid rgba(0,0,0,0.22);
  padding-top: 6px;
}



.article-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 36px;
  margin-top: 48px;
  align-items: start;
}

.article-card {
  padding: 24px;
  background:
    radial-gradient(circle at top left, rgba(120, 220, 255, 0.14), transparent 38%),
    linear-gradient(145deg, rgba(20, 70, 120, 0.34), rgba(4, 12, 28, 0.94));
  border: 1px solid rgba(130, 220, 255, 0.38);
  box-shadow:
    0 0 26px rgba(0, 140, 255, 0.16),
    inset 0 0 18px rgba(120, 220, 255, 0.07);
  color: #7bd7ff;
  text-align: left;
  cursor: pointer;
  font-family: Georgia, "Times New Roman", serif;
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

.article-card:hover {
  transform: translateY(-4px);
  border-color: rgba(180, 235, 255, 0.65);
  box-shadow:
    0 0 36px rgba(0, 160, 255, 0.28),
    inset 0 0 20px rgba(120, 220, 255, 0.09);
}

.article-card span {
  display: inline-block;
  margin-bottom: 10px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #7bd7ff;
}

.article-card h2 {
  margin: 0 0 12px;
  color: #c8f3ff;
  font-size: 1.25rem;
  text-transform: uppercase;
  text-shadow: 0 0 10px rgba(120, 220, 255, 0.35);
}


.article-card p {
  margin: 0;
  line-height: 1.55;
  font-size: 0.96rem;
}


.article-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  padding: 32px;
  background: rgba(0, 4, 12, 0.88);
  z-index: 9999;
  overflow-y: auto;
}

.article-lightbox.is-open {
  display: block;
}

.article-modal {
  position: relative;
  max-width: 980px;
  margin: 40px auto;
  padding: 34px;
  background:
    radial-gradient(circle at top left, rgba(120, 220, 255, 0.18), transparent 42%),
    linear-gradient(145deg, rgba(12, 42, 82, 0.96), rgba(3, 8, 20, 0.98));
  border: 1px solid rgba(150, 225, 255, 0.5);
  box-shadow:
    0 0 60px rgba(0, 160, 255, 0.32),
    inset 0 0 28px rgba(120, 220, 255, 0.08);
}

.article-modal-close {
  position: sticky;
  top: 0;
  float: right;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(150, 225, 255, 0.45);
  background: rgba(5, 15, 32, 0.9);
  color: #c8f3ff;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 0 18px rgba(0, 140, 255, 0.2);
}

.article-modal-content {
  color: #7bd7ff;
}

.article-modal-content h2 {
  margin: 0 0 24px;
  color: #c8f3ff;
  font-size: clamp(1.8rem, 4vw, 3.4rem);
  text-transform: uppercase;
  line-height: 0.95;
  text-shadow:
    0 0 14px rgba(120, 220, 255, 0.42),
    0 0 34px rgba(0, 130, 255, 0.24);
}

.article-modal-content p {
  max-width: 760px;
  margin: 0 auto 1.4em;
  font-size: 1.08rem;
  line-height: 1.75;
  color: #7bd7ff;
}

.modal-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}

.modal-gallery img {
  width: 100%;
  display: block;
  border: 1px solid rgba(130, 220, 255, 0.34);
  box-shadow: 0 0 22px rgba(0, 140, 255, 0.18);
}

.modal-gallery.featured img:first-child {
  grid-column: 1 / -1;
}

.intro-card,
.conclusion-card {
  grid-column: 1 / -1;
  width: min(560px, 100%);
  justify-self: center;
}

.intro-card {
  margin-bottom: 28px;
}

.conclusion-card {
  margin-top: 34px;
}
.article-card:nth-child(1) {
  grid-column: 2;
  grid-row: 1;
  justify-self: stretch;
}

.article-card:nth-child(2) {
  grid-column: 1;
  grid-row: 2;
}

.article-card:nth-child(3) {
  grid-column: 2;
  grid-row: 2;
}

.article-card:nth-child(4) {
  grid-column: 3;
  grid-row: 2;
}

.article-card:nth-child(5) {
  grid-column: 2;
  grid-row: 3;
}

@media (max-width: 900px) {
  .article-cards {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .intro-card,
  .conclusion-card {
    grid-column: auto;
    margin-top: 0;
    margin-bottom: 0;
  }

  .article-lightbox {
    padding: 16px;
  }

  .article-modal {
    margin: 20px auto;
    padding: 24px;
  }

  .modal-gallery {
    grid-template-columns: 1fr;
  }
}
body.manifesto {
  margin: 0;
  min-height: 100vh;
  background: #02040a;
}
.hidden-articles,
.hidden-articles article,
.hidden-articles .modal-gallery,
.hidden-articles img {
  display: none !important;
}